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© An apparatus and method for motion video encoding employing an adaptive quantizer. 



© An apparatus and method for encoding of a video picture is disclosed. The video picture has a plurality of 
pictures. The pictures each have a plurality of macroblocks. The macroblocks each have a plurality of sub- 
blocks. The apparatus comprising a first module configured to generate a transform coefficient Cjj for each of the 
sub-blocks of the macroblock. The apparatus further comprises a second module configured to variably quantize 
the transform coefficient by a scaling factor Q p based on the complexity of the picture and any rate control 
requirements. 
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The present invention relates generally to video imaging systems and methods. More particularly, the 
present invention relates to a system and method for digital still picture and motion video compression. 

Due to the current interest in digital multimedia interactive programs, there has been extensive activity 
in the international standards bodies dealing with still picture and motion video compression. In particular. 

s the Motion Picture Experts Group (MPEG), a group working under the sponsorship of the International 
Standards Organization, is rapidly converging towards a standard for the compression of digital motion 
video. One of the interesting features of this standard is that only the "decoding" algorithm syntax will be 
specified in detail. It will be thus posstble to have different encoders, all of which produce bit streams 
compatible with the standard's syntax, and yet result in different levels of video quality. The MPEG video 

jo standard is fully described in ISO-lEC JTC1/SCZWG1 1, MPEG 90/176 Rev. 2, December 18, 1990. This 
reference is hereby incorporated in its entirety into this disclosure. The MPEG standards will be briefly 
discussed herein. 

Generally, the MPEG video standard defines a layered architecture for compressing a video sequence. 

First, a sequence of video pictures is subdivided into disjoint Groups of Pictures (GOP). Each GOP is 
is compressed independently of other GOPs to facilitate random access to any picture and also to limit the 

propagation of transmission errors. 

Every picture in a GOP is subdivided into Macro-Blocks (MB). For a color picture, a MB is a collection 

of 16 x 16 luminance pixels and two 8 x 8 blocks of chrominance pixels. In MPEG, the two chrominance 

components are sampled at half the horizontal and vertical resolution of the luminance. As such, a MB 
20 completely describes a 16 x 16 color segment of a picture. In a MB, the 16 x 16 luminance pixels are 

further subdivided into four luminance blocks of 8 x 8 pixels. 

MBs can be coded into two modes, namely: intra and predictive. In intramode, a MB is coded 

independently of pixel data in previous or future pictures. In predictive mode a MB is coded with reference 

to pixel data in either a previous (forward prediction), a future picture (backward prediction), or both 
25 (interpolate prediction). A prediction is formed by applying motion compensation techniques to the 

referenced pictures, and an MB error data is generated by subtracting the prediction from the original pixel 

data. 

The MPEG standard requires that the first picture in a GOP be coded as an intrapicture. An intra picture 
is defined as having all of its MBs coded in the intramode. The remaining pictures of a GOP are then coded 

30 as either unidirectional predictive pictures (i.e., its MBs are coded in a mixture of intramode and forward 
prediction) or bidirectional predictive pictureslT.e., its MBs are coded in any of the MB coding modes). 

The still or motion picture data in the form" of MB's (represented by either the actual MB pixel data 
(intramode) or only the error data (predictive) to be compressed is then inputted to a first compression step. 
This first compression step is a transformation applied by a 2-dimensional 8x8 Discrete Cosine Transform 

35 (OCT) to each of the MB blocks. 

After applying the DCT to the six blocks in a MB, MPEG suggests that the resulting transform 
coefficients undergoes a second compression step. This second compression step is a scaling and 
truncation step (referred to in the art as "quantization"). Each of the DCT coefficients are uniformly 
quantized with a matrix of quantization steps. MPEG specifies one of two reference matrices from which the 

40 quantization steps may be derived. The choice of which matrix depends on the MB mode. This second step 
is an additional compression step which is necessary to achieve adequate compression of the picture data. 
Although the reference matrices can be defined by the encoder at the beginning of a video sequence, they 
remain fixed afterwards. MPEG allows dynamic changes to the matrix of quantization steps, however, by 
allowing a scaling factor for the reference matrices; this scaling factor can be changed for every MB. 

45 MPEG, however, does not disclose an apparatus or method for determining and changing the scaling factor. 
Keeping this scaling factor constant may result in the unnecessary loss of picture quality during the 
compression mode. 

The present invention is directed to providing an apparatus and method for determining and changing 
the scaling factor left undefined by MPEG. An apparatus and method that performs this function is defined 

50 as adaptive quantization (AQ). As such, the present invention is an apparatus and method for encoding still 
and motion pictures employing an adaptive quantization feature to the transform coefficients for improved 
quality of still pictures and motion video compression. 

The adaptation is performed on a MB to MB basis and varies based on the complexity of the image 
and the available rate control requirements. 

55 In one embodiment, the encoder of the present invention comprises a transform coefficient module and 
an adaptive quantization module. The transform coefficient module of the preferred embodiment employs a 
conventional Discrete Cosine Transform (DCT) function to generate a transform coefficient C (j for each sub- 
block of a macroblock. 
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Each transform coefficient Cjj is then inputted to the adaptive quantization module where it is variably 
quantized based on (1) the complexity of the image and (2) any rate control requirements that may be 
present in the encoding apparatus. 

In one embodiment, the adaptive quantization module is configured to perform a first step quantization 
5 followed by a second step quantization. In the first step, each transform coefficient is scaled by a fixed 
weighting factor matrix to yield a partially quantized coefficient Cw^. Two matrices can be defined in MPEG. 

The second quantization step is that of scaling Cwjj by a second scaling factor q p which remains 
constant for all Cwjj in a macroblock, but can vary from macroblock to macrobtock to yield a fully quantized 
coefficient Cq^. In one embodiment, the scaling factor q p is determined based on the complexity of the 
w picture (macroblock) as measured by Cw^ and the rate control requirements. 

With regard to the complexity of the picture, the adaptive quantization module will select the scaling 
factor q p based on a minimax algorithm applied to the Cwjj coefficients of the four luminance blocks 
contained in a MB. 

In this regard, when the picture is complex the user will not be visually suspectible to image 
is abnormalities. As such, the quantization factor, q p , may be high, thus reducing the number of bits used. In 
contrast, when the picture is not complex, the user is susceptible to image abnormalities. As such, the 
quantization factor, q p , may be low, thus reducing compression but at the cost of increasing the number of 
bits used. The minimax algorithm senses the complexity of the picture and is used, in part, to determine q p . 
With regard to rate control requirements, encoders typically employ an equalizing buffer to ensure that 
20 a mechanism exists for equalizing the variable bit rate at which data is generated by compression and the 
constant bit rate that is typical of many storage media. The equalizing buffer has an upper and lower rate 
control requirement. The lower rate control requirement is such that a minimum amount of information must 
always be stored in the buffer. The upper rate control requirement is such that only a maximum amount of 
information can be stored in the buffer at a given time. As such, it is important that the q p ensure that the 
25 occupancy of the buffer stay within these upper and lower bounds. 

Accordingly, the present invention strikes a balance between maximization of the quality of the image 
while staying within the upper and lower boundaries of the rate control requirements. 

Although the present invention is described in the context of the MPEG standard, it should be clear that 
the present invention is applicable to any video compression scheme that is transform based. The nature of 
30 the transform (Discrete Cosine, Hadamard, Lapped Overlapped, etc.) and the size and/or structure of the 
transform blocks and MB can be changed without affecting the fundamental ideas of this invention. For 
example, a macroblock could be re-defined to contain fewer or more of the blocks defined in MPEG. 

The foregoing and other objects, features and advantages of the invention will be apparent from the 
following more particular description of (a) preferred embodiment(s) of the invention, as illustrated in the 
as accompanying drawing(s). 

The following detailed description of the present invention will be more fully understood with reference 
to the accompanying drawings in which: 

FIGURE 1 is a high level block diagram showing of the motion picture encoder of the present invention; 
FIGURE 2 is a block diagram showing the transformation coefficient module and adaptive quantization 
40 module of the present invention; 

FIGURE 3 is a more detailed block diagram showing the architecture of the adaptive quantization 
module; and 

FIGURE 4 is a more detailed block diagram showing the architecture of the q p selection module. 
The present invention is an apparatus and method for encoding of still or motion pictures. The encoder 
45 of the present invention employs an adaptive quantization (AQ) feature such that the quantization of the 
picture data is automatically varied to produce the high quality image while maintaining acceptable bit rate 
control requirements. 

Referring to FIGURE 1, where a high level block diagram of the motion picture encoder 100 of the 

present invention is illustrated. As shown, the motion picture encoder 100 generally comprises an input 
so device 102 for inputting a sequence of motion pictures. The input device 102 may be, for example, the 

output from a digital video cassette recorder or a digitized output from any analog image capture device, 

such as a camera. VCR. and the like. 

The digital motion picture is inputted by input device 102 along a bus 104 to an encoder 106. As will be 

described more fully herein, the encoder 106 of the present invention is configured to perform a 
55 transformation and quantization step. As will also be more fully described, the quantization step of the 

present invention is based on the complexity of the image and the rate control requirements of a buffer 118 

(to be described). 

Further shown is a bit allocator 108. Bit allocator 108 is provided to allocate a specific numbers of bits 
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for each picture Bit allocator 108 may take a number of configurations. In one embodiment, the bit allocator 
,08 may be configured to assign exactly the same number of bits to each picture. Alternative y Uje brt 
allocator 108 could be configured such that the number of bits allocated is dependent on the picture being 
p oS ^ sed For exa mp , e , the MPEG group in document ISO/JEC JTC1'SC2 / W611. MPEG 90/4, July, ,990 
s disclosed a method for variable bit rate allocation., This reference is hereby incorporated by reference m , its 
entity tto Thts specification. As wi.l be shown more fully herein, the encoder ,12 of the present invention 
can be configured to operate with a variety of bit allocation strategies. 

The compressed data picture is then outputted along a bus ,12 to a vanable length coder (VLC) ,4 
where the encoded information is represented by at leas, one bit. VLC encoding is well known ,n the art and 
to is a further compression step. .„„ 11ft 

After the compressed data is coded by the VLC ,14. it is outputted along a bus 116 to a buffer ,ia 
Buffer ,18 is provided so as to equalize the variable bit rate of the compressed data ^mg outputted by 
VLC 1,4 on bus ,16 with the constant bit rate of a storage device ,22. A storage device ,n this case^ may 
be for example any media operating at a fixed data rate. For example, one common bit rate is that of Cf> 
, 5 ROM which operates at about a bit rate of 1.5 Mbit/s. As such, it ,s important to (1) ensure that there ,s 
always enough data in the buffer , , 8 and (2) that buffer , , 8 is not-overflowed. 

Further shown is a bus ,24. Bus ,24 allows the encoder ,06 to sense the "fullness" (either too low or 
too high) of buffer ,,8. As will be described more fully herein, the encoder 106 is configured to quant.ze the 
transform coefficient by a scaling ratio wh.ch is determined based on the "fullness of the buffer ,,8 and 

20 the complexity o, the video picture. m , ar , nR . .nitrated As 

Referring now to FIGURE 2, where a high level block diagram of the encoder ,06 .s •llustrated. As 
shown the encoder ,06 first comprises a transform coefficient device 202. 

The transform coefficient device 202 is provided to transform each MB into a corresponding transform 
coefficient. In the preferred embodiment, the transform coefficient device 202 ,s configj 
Discrete Cosine Transform (OCT) function. The OCT algorithm is well known in the art and w.ll no, be 
deSbed l Z2. As a result of the transform coefficient device 202. each b.ock in an MB is transformed 
into a set of transform coefficients Qj. n^wiro ?nR Tha 

The C (j for each block is then outputted along a bus 204 to an adaptive ^ ant, ^ on ^ e " C ^ or ^ 
adaptive quantization device 206 is configured to quantize each transform «*^^£JJ£S 
amount such as to achieve sufficient compression while maintaining image quality. The quantized transform 
coefficient is represented by Cq, The quantizing of each transform coefficient C, ,s thus not f.xed and is 
hased on the (1) fullness of the buffer 118 and (2) the complexity of the image. 
^ Th mattiemaL. foundation for the present invention wil, now be 

uniform quantization of an 8 x 8 matrix of transform coefficients C, can be described by the following 
35 equation; 



25 



30 



40 



where INTEGERS extracts the integer portion of x; C (i are the transform coefficients, and Cq, are the 
r eS u Ld duanSd steps. Q, are the corresponding quantization steps. The parameter k takes the value o 
for ?„SS; -Grounding to the nearest integer and 0 for truncation. Note that throughout this 
45 JScSSSL transform coefficients are assumed. For negative coefficients, all va " d 
iUhe magnitude is extracted first and the sign is restored after the quant,zat,on process ,s comp.e ed_ 

For use within the MPEG standard. Equation [1] can be rewritten ,n a different way by making Q„ 
qpwij/8. In this case, 

C Ql1 = INTEGER 8 121 

55 where is a set o, quantization weights and q p is the quantization sca.ing factor. *J^***^^ 
two integer matrices of U|j can be defined to code a sequence. Additional.y. in the MPEG i s^dards ^a 
allowed to vary between , and 31 on a MB to MB basis. It ,s this vanab.lity that perrmts adaptive 
q " antizat on. The apparatus and method of the present invention determines the appropriate value for q, As 
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will be more fully described herein, the present invention automatically chooses q p such as to optimize the 
visual appearance of a video sequence while maintaining a constant average output data rate. 

The present invention attempts to distribute the available bits equally among ail MBs in a picture. In this 
manner, MBs with high energy would be assigned a coarser quantizer than those with low-energy content. 
5 This assignment is in accordance with the results of many experiments with the human visual system that 
suggest that humans are more tolerant to errors in areas of a picture with great activity or energy. As such, 
q p should be selected according to some measure of energy content for a block (small transform coefficient 
C,j corresponds to little energy.) An alternative embodiment would also take into account the energy of 
neighboring MBs. 

io The assignment of q p , however, cannot be arbitrary. In applications where the output bandwidth is fixed, 
q p must also be used to control the average compressed data rate. Typically, quantized coefficients 
together with other data are coded by variable length codes. One consequence of this coding is that the 
data associated with a single video picture is not constant. In order to equalize the variable data rate at 
which compressed data is generated, and the output data rate at which it is transmitted, the data must be 
is buffered in the buffer device 118. Typically, the output data rate is constant. However, the apparatus and 
method of the present invention is equally applicable to embodiments where the output data rate is variable. 
Once the size of buffer 118 is chosen, the rate at which the compressed data is generated must be 
regulated so that the buffer 118 does not overflow or underflow (becomes empty). This rate control is also 
accomplished by dynamically modifying q p . The encoder 100 is capable of adapting q p to improve the 
20 overall quality of a picture while simultaneously satisfying the buffer 118 size constraints. 

In the preferred embodiment, the output data rate has a target rate of around 1 .5 Mbit/s with a video 
resolution of 352 x 240 x 30 pixels/s. As will become apparent to one of ordinary skill in the art. the present 
invention can be extended in trivial ways to operate at higher resolutions and bit rates. 

In one embodiment, the adaptive quantization device 206 operates to split the quantization process of 
25 Equation 2 into two steps; a quantization by <j }j followed by a quantization by q p . in between these two 
steps, the value of q p is selected based on the results of the first step as well as on the fullness of the 
output data rate equalizing buffer 118. 

Returning now to FIGURE 3, a block diagram illustrates one embodiment of the adaptive quantization 
device 206. 

30 As shown by Figure 3, the transform coefficients Cy areinputted to a first multiplier 302 where they are 
multiplied with 2 4 */w lj which quantity is inputted by a block 304 along a bus 306. This is the first quantization 
step and yields a partially quantized coefficient Cw^. The scaling factor 2 W can be selected such that enough 
precision is maintained even if ail operations are carried out with integer arithmetic. Since the values of ^ 
do not change for a video sequence, the multiplicative factors 2 w /o> i} will also remain constant and they only 

as need be computed once at the beginning of a sequence. The pre-computed values could be stored with 
arbitrary precision in a table of 64 integers (one for each of the 8 x 8 transform coefficients). In MPEG, two 
wjj matrices are allowed and therefore two tables are needed. 

Thereafter, the output of multiplier 302 (Cwjj) is inputted to a second multiplier 310 where Cwjj is 
multiplied by 2 q /q p , denoted by a block 312. This is the second quantization step. However, unlike the first 

40 quantization step, q p isvariable and is determined by a q p selection device 314. The scaling factor 2 q can be 
selected such that enough precision is maintained even if all operations are carried out with integer 
arithmetic. As will be shown more clearly below, quantization by q p can be carried out through multiplication 
by one of 31 pre-stored integer values corresponding to all possible 2 q/ q p values in MPEG. In this case, the 
q exponent determines the precision of the results of this step. There are extensions of this idea that 

45 improve further the precision of the arithmetic operations without increasing the number of bits required for 
the intermediate quantization results. For example, one could split the multiplication by 2 4J /wj j into a 
multiplication by 2 w * m /wjj followed by normalization (division or binary shift) by 2 m . Of course, if floating 
point arithmetic is available, no power of two scaling is necessary. 

As such, the quantization step defined mathematically by Equation [2] and illustrated in Figure 3 is split 

so into two separate steps. The first step is mathematically expressed as: 

Cw tj = INTEGERi^ C X A i,j - 1 8 [3] 

55 

where Equation 3 is carried out in the multiplier 302. The second step can be expressed as: 
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1 



2 >-«-<* INTEGER [ — GV J: ,*2 tt *«- 4 Jc] i.j'l. 8 (4] 



10 



where Equation 4 is carried out by the multiplier 310. adder 320, and multiplier 328. In Equation 4, the value 
of q p is chosen based, at least in part, on the values of Cw i( and thus the energy level (or complexity) of the 

maC |t°shou l |d be understood that if a floating point processor is used, « and q can be set equal to zero. 
The resultant quantized transform coefficient Cq, is then outputted on the bus 112 to the VLC device 

114 As discussed before. q p is selected on the basis of the energy content of transform blocks, and 
alternatively their neighborhood, as well as on the basis of buffer 118 fullness and bit allocate .consider 

, 5 ations. The h.gher the value of q, the more compressed the picture becomes. As such, he fewer b t .need 
to be allocated but at the cost of image quality. For high energy pictures, it has been found that the user 
cannot easily notice image abnormalities. In contrast, for low energy pictures the user can easily notice 
image abnormalities. As such, q p should be as low as possible for low energy pictures thus reducing 
compression. In the case of MPEG, because an MB naturally defines a neighborhood of four 8 x 8 

20 luminance blocks, it constitutes a natural unit for measuring energy. However, because of rate control 
requirements. q p has an upper and lower limit. As such, it is desirable to maximize the image quality only 
when needed while staying within the rate control limits. 

The q D selection device 31 4 is configured to operate generally as follows: 

1. Select a first quantizer factor, q p ° in the range between t and 31 on the bas.s of b.t al.ocat.on and 
25 buffer 118 fullness control considerations. The actual method of selection is not important and could be 
one of many possibilities. For example the above-referenced document. MPEG 90/41, descnbes one 

2 U SelTct a°second quantizer factor. q p -\ on the basis of energy considerations for a MB. The preferred 
method for this selection is based on the determination of the minimum of the max.mum energy content 
transform coefficient for a given macroblock. This can be expressed by the following steps: 

a. For the 4 luminance blocks in an MB, obtain the maxima of the partially quantized Cw„ coefficients 
of each luminance block. This can be represented as 



30 



35 



Jb-i 4 [5a] 



where the index b represents each of the four luminance blocks in a MB. 
40 b. Determine Cw m i nima x as 

- ^ ICW&J [5b] 

In other words, determine the minimum of the four maximum Cw max » partially quantized transform 
coefficients (Cw.) corresponding to each luminance block in a MB. 

c. Select q p '°" such that Cq_ is a predefined value, Le. using Equation 4 for example, 

C qainlMX - 2— INTEGER^ Cw minl ^2^'*k) [5c] 



45 



50 



55 



For the case of Cq_ = 2". the derivation of q p - can be simplified significantly if the rounding 
factor (k = 0) is ignored. In this case, 
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5 3. The final q p selection is based on q p ,ow , appropriately bounded to satisfy rate control and other 
constraints. For example, because q p ° is chosen on the basis of rate control considerations, a large value 
of q p ° suggests that the rate-equalizing buffer 118 is close to full and that we should choose q p s q p °. 
On the other hand, if the buffer 118 is far from full, any q p a q p ,ow s q p o is acceptable. A heuristic that 
works fairly well in MPEG where q p varies between 1 and 31 is 

w 

q p » min {g° p , max { q* ow , integez (1+30 [^i ] tt ] ) ) [7] 

where a > 1. In particular, for a rate around 1.5 Mbit/s, a = 2.5 works well. 

As will be obvious to one skilled in the art. other heuristics are equally possible. An additional 
confirmation of the q p selection device 314 could insure that no quantized luminance coefficient exceeds a 
maximum value. MPEG requires, for example. Cqij < 2*. This requirement can be satisfied by insuring that 
20 the final q p is at least as large as the value of q p min defined below 



25 



cfr a = 2 3 -*- 8 Ct/^^ [9] 

30 



Obviously, these constraints can also be extended to the chrominance blocks. 

Referring now to Figure 4, wherein the q p selection device 314 is described in more detail. 
35 As shown, the partially quantized transform coefficients Cwjj are inputted along a bus 316 to a first latch 

402. First latch 402 is provided to ensure that only one transform coefficient is passed to a max select 

module 406 (to be described). The first latch 402 only holds the data for one clock cycle. 

The transform coefficients are than outputted along a bus 404 to the max select module 406. The max 

select module 406 is provided to determine the maximum transform coefficient for each of the four sub- 
40 blocks of each macroblock. Operation of max select module 406 is equivalent to the mathematical 

expression of Equation 5a. 

The second latch 410 is initialized to zero. After 64 cycles, the second latch 410 will contain the 

maximum value among the first 64 transform coefficients Cw^ of a single 8x8 pixel block which also 

corresponds to one sub-block within a macroblock. 
45 At this point, a 64 cycle counter 403 operates to clear the second latch 410 and likewise reset the 

operation of the first latch 402 and first max select module 406. The first latch 402 and the first max select 

module 406 are then ready for the next sequence of transform coefficients that represent the next sub-block 

of the macroblock. 

In short, the function of first max select module 406, first latch 402, and second latch 420 is to simply 
50 pick the maximum transform coefficient Cw^ of each sub-block within the macroblock. 

The 64 cycle counter 403 after reading 64 cycles knows that the second latch 410 contains the 
maximum transform coefficient Cw^ that corresponds to the current sub-block. As such, this maximum value 
is outputted along a bus 412 to a first min select module 414. Min select module 414 is configured to 
determine the minimum transform coefficient of the four maximum transform coefficient calculated for one 
55 macroblock. This is defiend as Cw minjmax . Operation of min select module 414 corresponds to the 
mathematical relationship of Equation 5b. 

In operation, third latch 420 is initialized to a very large value. Therefore, every time the first counter 
403 reaches the count of 64 cycles, the min select module 414 is prompted to take one comparison. The 
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comparison is with the current value stored in the third latch 420 and the current maximum ransform 
coefficient Cw, being inputted to the min select modu.e 414 along bus 41 2. As such, after four cycles of he 
first 64 cycle counter 403. the third latch 420 will be loaded w,th the m.mmum value of the maximum 
transform coefficient Cw, of the 4 blocks of a macroblock defined as Cw minimax . The 4 cycle counter ^405 is 
essentially the one that counts the 4 blocks. When the 4 luminance blocks of a macroblock have gone 
throuqh this process, then the fourth latch 426 gets loaded with Cw mi „, ma)< along a bus 424. 

At that point. Cw . is outputted to a multiplier 430 where it is normalized to the correct power 

denoted by block 432. The output of multiplier 430 is q„-. The operation of multiplier 430 corresponds to 
the mathematical expression given by equation 6. . . . 

The value for a,- is then outputted to a second max select module 436. The max select module 436 ,s 
generally provided to ensure that the ultimate value chosen for q p is not below the lower bounds of any rate 

control requirements. , , . . . 

The output of the max select module 436 is a value of q p greater or equal than a value below which you 
cannot go because of rate control requirements. If a lower value is elected, the rate equaling buffer may 
begin to overflow, thus causing information to be lost. If q P "~ goes below the lower bound, then the max 
select module 436 will select instead the lower bound value for q p calculated by the lower bound select 
module 440 (to be described). 

The value outputted by the max select module 436 is outputted to a mm select module 444. The mm 
select module 444 is provided to insure that an ultimate value for q p is chosen that is less or equal to a 
value above which you cannot go because of rate control requirements. In other words, the max select 
module 436 will not allow q p '~ to go above some maximum value q P °. In this case, the concern for rate 
control is that of underf lowing the equalizing butfer. It could be that the buffer is almost empty and it does 
not have data to transmit. As such, the min select module 444 ensures that the final q p selectedw.ll not be 
above a certain value which is required for rate control. This value of q p ° is calculated I from a measure of 
butter fullness. As discussed, one method for calculation of q p ° is described in MPEG 90/41. 

Finally the set of blocks incorporated in 460 can be used to implement equations 8 and 9 We recal 
that the purpose of these equations is to define a value q p min which is a lower bound for q p that 
guarantees that the final quantized coefficients Cq, will not exceed a pre-defmed maximum Jl will be 
recalled that the devices 414. 420, 426, 430. and 432 implement the mathematical equations 5b and 6. The 
devices incorporated in module 460 are the same except, for replacing a mm select for a max select. Th.s 
is also the difference between Equations 5b and 6, and their corresponding Equations 8 and 9^ 

It should be understood that the quality of intramode MBs is important for the overall video quality. In 
particular, the quality of the MBs in an intrapicture of a GOP is crucial for determining the quality of the rest 
of the pictures in that GOP. At low bit rates, the most objectionable distorts of many Jans to™ based 
schemes is the appearance of blockiness due to coarse quantization of the transform coeffic.ents that lead 
o a mi match oT pixel intensities around the edges of the transformed blocks. This blockiness ,s most 
visible m areas of the picture that are relatively smooth, Le. where there is little luminance activity. Once 
n reduced, intrapicture blockiness tends to remain for the rest of a GOP; it is thus important to mittgate ,, ,n 
those areas where they are most visually annoying. Areas of low luminance activity are characterized by _ the 
ow energy content in the AC coefficients of their OCT transform. The DC coefficient however on*** "J» 
the average value of a pixe. block and not its activity. For this reason, the P^sent invention apples he 
algorithm of FIGURE 4 only to the 63 AC coefficients and not to the one DC coefficient. In addition, for 
coding around 1.5 Mbit/s, the preferred value of Cq minima x "S 2. 

Adaptive quantization in Predictive MB's is slightly different. In this case, the DC coefficients should be 
included in the process of FIGURE 4. For coding at around 1.5 Mbit/S it is useful to only apply ada P t,ve 
quantization to the MBs in the forward predictive pictures. For this case. Cq™,™ - 1 'S pte ™' e °. 

While the invention has been particularly shown and described with reference to preferred embodiments 
thereof it will be understood by those skilled in the art that the foregoing and other changes in form and 
details may be made therein without departing from the spirit and scope of the invention. 
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Claims 
1. 



An apparatus for encoding of a video picture, the video picture having a plurality of f«"°*J** 
pictures each having a plurality of macrob.ocks. the macrob.ocks each having a plurality of sub-blocks. 

55 ^S^^X^ - generate transform coefficients C, for each of the sub-blocks of the 

rbrateco'nVmodule configured to variably quantize said transform coefficients, said second modu.e 
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being further configured to quantize said transform coefficients Qj in a first quantization step 
followed by a second quantization step, said first quantization step being quantization by a matrix of 
weights in a predefined matrix to generate a set of partially quantized coefficients Cw }j for each of 
the sub-blocks of the macro block, said second quantization step being quantization by a variable 
scaling factor q p based on the calculation of said Cwjj for each sub-block in the macroblock. 

2. The apparatus of claim 1. wherein said q p is based on the calculation of Cw minjmax where Cw minjmax is 
the minimum of the maximum of the Cw^ for each sub-block of the macroblock. 

3. The apparatus of claims 1 or 2. wherein q p is also based on the rate control requirements of an output 
equalizing buffer. 

4. The apparatus of claim 3, wherein said rate control requirements consist of an upper boundary and a 
lower boundary for said scaling factor q p . 

5. The apparatus of claim 4, wherein q p is selected from among said Cw mjnimax , said upper and lower 
bounds of said rate control requirements. 

6. A method for encoding of a video picture, the video picture having a plurality of pictures, the pictures 
each having a plurality of macroblocks. the macroblocks each having a plurality of sub-blocks, the 
method comprising the step of: 

(a) generating a transform coefficient Qj for each of the sub-blocks of the macroblock; and 

(b) generating a variable quantization factor Q p , said step of generating a variable quantization factor 
Q p comprises the step of performing a first quantization step followed by a second quantization step, 
said first quantization step being quantization by a fixed scaling weight «> n to thereby generate a 
partially transformed transform coefficient Cw^, said second quantization step being quantization by 
a variable scaling factor q p based on the calculation of said Cw^ for each sub-block in the 
macroblock; and 

<c) scaling said transform coefficient C,-j by said quantization factor Q p to generate a quantized 
transform coefficient Cq ti . 

7. The method of claim 6, wherein step (b) further comprises the step of determining q p based on the 
calculation of a Cw minjmax , where said Cw minjmax is the minimum of the maximum of said Cw^ for each 
sub-block of the macroblock. 

8. The method of claims 6 or 7, wherein step (b) further comprises the step of determining q p based on 
the rate control requirements of an output equalizing buffer. 

9. The method of claim 8, wherein step (b) further comprises the step of determining the rate control 
requirements based on an upper boundary and a lower boundary for said variable scaling factor q p . 

10. The method of claim 9, wherein step (b) further comprises the step of selecting q p is from among said 
Cw minimax , said upper and tower bounds of said rate control requirements. 
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